const fp = require('lodash/fp')
// 数据：horsepower 马力，dollar_value 价格，in_stock 库存
const cars = [
  { name: 'Ferrari FF', horsepower: 660, dollar_value: 700000, in_stock: true },
  { name: 'Spyker C12 Zagato', horsepower: 650, dollar_value: 648000, in_stock: false },
  { name: 'Jaguar XKR-S', horsepower: 550, dollar_value: 132000, in_stock: false },
  { name: 'Audi R8', horsepower: 525, dollar_value: 114200, in_stock: false },
  { name: 'Aston Martin One-77', horsepower: 750, dollar_value: 185000, in_stock: true },
  { name: 'Pagani Huayra', horsepower: 700, dollar_value: 130000, in_stock: false }
]

/**
 * 练习1、使用组合函数 fp.flowRight() 重新实现下面这个函数
    let isLastInStock = function(cars){
      // 获取最后一条数据
      let last_car = fp.last(cars)
      // 获取最后一条数据的 in_stock 属性值
      return fp.prop('in_stock', last_car)
    }
 */

const f1 = fp.flowRight(fp.prop('in_stock'), fp.last)
console.log(f1(cars))

/**
 * 练习2、使用 fp.flowRight()、fp.prop() 和 fp.first() 获取第一个 car 的 name
 */

const f2 = fp.flowRight(fp.prop('name'), fp.first)
console.log(f2(cars))

/**
 * 练习3、使用帮助函数 _average 重构 averageDollarValue，使用函数组合的方式实现
    let _average = function(xs){
      return fp.reduce(fp.add, 0, xs) / xs.length
    }
    let averageDollarValue = function () {
      let dollar_value = fp.map(function (car) {
        return car.dollar_value
      }, cars)
      return _average(dollar_value)
    }
 */

let _average = function(xs){
  return fp.reduce(fp.add, 0, xs) / xs.length
}
const averageDollarValue = fp.flowRight(_average, fp.map(fp.prop('dollar_value')))
console.log(averageDollarValue(cars));

/**
 * 练习4、使用 flowRight 写一个 sanitizeNames() 函数，返回一个下划线连续的小写字符串，把数组中的 name 转换为这种形式
 * 例如：sanitizeNames(["Hello World"]) => ["hello_world"]
 */
let _underscore = fp.replace(/\W+/g, '_');
// 先写一个将["Hello World"]) => ["hello_world"]的flowRight
// fp.flowRight(_underscore, fp.toLower)
// 再将数组中的每一项的name用相关方法替换
const sanitizeNames = fp.flowRight(_underscore, fp.toLower)
const cars1 = cars => {
  return fp.map(f => {
    return {...f, name: sanitizeNames(f.name)}
  }, cars)
}
console.log(cars1(cars))